<template>
  <Tooltip :title="t('layout.header.tooltipLock')" placement="bottom" :mouseEnterDelay="0.5" @click="handleLock">
    <LockOutlined />
  </Tooltip>
  <LockModal @register="register" />
</template>
<script lang="ts">
import {defineComponent} from 'vue';
import {createAsyncComponent} from '/@/utils/factory/createAsyncComponent';
import {Tooltip} from 'ant-design-vue';
import {LockOutlined} from '@ant-design/icons-vue';
import Icon from '/@/components/Icon';
import {useI18n} from '/@/hooks/web/useI18n';
import {useModal} from '/@/components/Modal';

export default defineComponent({
    name: 'LockScreen',
    inheritAttrs: false,
    components: {
      Icon,
      Tooltip,
      LockOutlined,
      LockModal: createAsyncComponent(() => import('./lock/LockModal.vue')),
    },
    setup() {
      const { t } = useI18n();
      const [register, { openModal }] = useModal();

      function handleLock() {
        openModal(true);
      }

      return {
        t,
        register,
        handleLock,
      };
    },
  });
</script>
